TABLE 7-2: PIC16CXXX INSTRUCTION SET

| Mnemonic,<br>Operands |      | Description                  | Cycles  |       | 14-Bit ( | I-Bit Opcode |      | Status   | Notes |
|-----------------------|------|------------------------------|---------|-------|----------|--------------|------|----------|-------|
|                       |      | Description                  |         | MSb   |          |              | LSb  | Affected | Notes |
|                       |      | BYTE-ORIENTED FILE REGIS     | TER OPE | RATIO | NS       |              |      |          |       |
| ADDWF                 | f, d | Add W and f                  | 1       | 0.0   | 0111     | dfff         | ffff | C,DC,Z   | 1,2   |
| ANDWF                 | f, d | AND W with f                 | 1       | 0.0   | 0101     | dfff         | ffff | Z        | 1,2   |
| CLRF                  | f    | Clear f                      | 1       | 0.0   | 0001     | lfff         | ffff | Z        | 2     |
| CLRW                  | -    | Clear W                      | 1       | 0.0   | 0001     | 0xxx         | xxxx | Z        |       |
| COMF                  | f, d | Complement f                 | 1       | 00    | 1001     | dfff         | ffff | Z        | 1,2   |
| DECF                  | f, d | Decrement f                  | 1       | 0.0   | 0011     | dfff         | ffff | Z        | 1,2   |
| DECFSZ                | f, d | Decrement f, Skip if 0       | 1 (2)   | 0.0   | 1011     | dfff         | ffff |          | 1,2,3 |
| INCF                  | f, d | Increment f                  | 1       | 0.0   | 1010     | dfff         | ffff | Z        | 1,2   |
| INCFSZ                | f, d | Increment f, Skip if 0       | 1 (2)   | 0.0   | 1111     | dfff         | ffff |          | 1,2,3 |
| IORWF                 | f, d | Inclusive OR W with f        | 1       | 0.0   | 0100     | dfff         | ffff | Z        | 1,2   |
| MOVF                  | f, d | Move f                       | 1       | 0.0   | 1000     | dfff         | ffff | Z        | 1,2   |
| MOVWF                 | f    | Move W to f                  | 1       | 0.0   | 0000     | lfff         | ffff |          |       |
| NOP                   | -    | No Operation                 | 1       | 0.0   | 0000     | 0xx0         | 0000 |          |       |
| RLF                   | f, d | Rotate Left f through Carry  | 1       | 0.0   | 1101     | dfff         | ffff | С        | 1,2   |
| RRF                   | f, d | Rotate Right f through Carry | 1       | 0.0   | 1100     | dfff         | ffff | С        | 1,2   |
| SUBWF                 | f, d | Subtract W from f            | 1       | 00    | 0010     | dfff         | ffff | C,DC,Z   | 1,2   |
| SWAPF                 | f, d | Swap nibbles in f            | 1       | 0.0   | 1110     | dfff         | ffff |          | 1,2   |
| XORWF                 | f, d | Exclusive OR W with f        | 1       | 00    | 0110     | dfff         | ffff | Z        | 1,2   |
|                       |      | BIT-ORIENTED FILE REGIST     | ER OPER | ATION | IS       |              |      |          |       |
| BCF                   | f, b | Bit Clear f                  | 1       | 01    | 00bb     | bfff         | ffff |          | 1,2   |
| BSF                   | f, b | Bit Set f                    | 1       | 01    | 01bb     | bfff         | ffff |          | 1,2   |
| BTFSC                 | f, b | Bit Test f, Skip if Clear    | 1 (2)   | 01    | 10bb     | bfff         | ffff |          | 3     |
| BTFSS                 | f, b | Bit Test f, Skip if Set      | 1 (2)   | 01    | 11bb     | bfff         | ffff |          | 3     |
|                       |      | LITERAL AND CONTROL          | OPERATI | ONS   |          |              |      |          |       |
| ADDLW                 | k    | Add literal and W            | 1       | 11    | 111x     | kkkk         | kkkk | C,DC,Z   |       |
| ANDLW                 | k    | AND literal with W           | 1       | 11    | 1001     | kkkk         | kkkk | Z        |       |
| CALL                  | k    | Call subroutine              | 2       | 10    | 0kkk     | kkkk         | kkkk |          |       |
| CLRWDT                | -    | Clear Watchdog Timer         | 1       | 00    | 0000     | 0110         | 0100 | TO,PD    |       |
| GOTO                  | k    | Go to address                | 2       | 10    | 1kkk     | kkkk         | kkkk |          |       |
| IORLW                 | k    | Inclusive OR literal with W  | 1       | 11    | 1000     | kkkk         | kkkk | Z        |       |
| MOVLW                 | k    | Move literal to W            | 1       | 11    | 00xx     | kkkk         | kkkk |          |       |
| RETFIE                | -    | Return from interrupt        | 2       | 00    | 0000     | 0000         | 1001 |          |       |
| RETLW                 | k    | Return with literal in W     | 2       | 11    | 01xx     | kkkk         | kkkk |          |       |
| RETURN                | -    | Return from Subroutine       | 2       | 00    | 0000     | 0000         | 1000 |          |       |
| SLEEP                 | -    | Go into standby mode         | 1       | 00    | 0000     | 0110         | 0011 | TO,PD    |       |
| SUBLW                 | k    | Subtract W from literal      | 1       | 11    | 110x     | kkkk         | kkkk | C,DC,Z   |       |
| XORLW                 | k    | Exclusive OR literal with W  | 1       | 11    |          | kkkk         |      | Z        |       |

Note 1: When an I/O register is modified as a function of itself (e.g., MOVF PORTB, 1), the value used will be that value present on the pins themselves. For example, if the data latch is '1' for a pin configured as input and is driven low by an external device, the data will be written back with a '0'.

**Note:** Additional information on the mid-range instruction set is available in the PICmicro™ Mid-Range MCU Family Reference Manual (DS33023).

<sup>2:</sup> If this instruction is executed on the TMR0 register (and, where applicable, d = 1), the prescaler will be cleared if assigned to the Timer0 Module.

<sup>3:</sup> If Program Counter (PC) is modified or a conditional test is true, the instruction requires two cycles. The second cycle is executed as a NOP.

#### **Instruction Descriptions** 7.1

| ADDLW            | Add Literal and W                                                                                                 |
|------------------|-------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ <i>label</i> ] ADDLW k                                                                                          |
| Operands:        | $0 \leq k \leq 255$                                                                                               |
| Operation:       | $(W) + k \to (W)$                                                                                                 |
| Status Affected: | C, DC, Z                                                                                                          |
| Description:     | The contents of the W register are added to the eight-bit literal 'k' and the result is placed in the W register. |

| BCF              | Bit Clear f                                   |
|------------------|-----------------------------------------------|
| Syntax:          | [label] BCF f,b                               |
| Operands:        | $0 \le f \le 127$<br>$0 \le b \le 7$          |
| Operation:       | $0 \rightarrow (f \mathord{<} b \mathord{>})$ |
| Status Affected: | None                                          |
| Description:     | Bit 'b' in register 'f' is cleared.           |

| ADDWF            | Add W and f                                                                                                                                                        |  |  |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Syntax:          | [label] ADDWF f,d                                                                                                                                                  |  |  |
| Operands:        | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                                 |  |  |
| Operation:       | (W) + (f) $\rightarrow$ (destination)                                                                                                                              |  |  |
| Status Affected: | C, DC, Z                                                                                                                                                           |  |  |
| Description:     | Add the contents of the W register with register 'f'. If 'd' is 0, the result is stored in the W register. If 'd' is 1, the result is stored back in register 'f'. |  |  |

| BSF              | Bit Set f                            |
|------------------|--------------------------------------|
| Syntax:          | [label] BSF f,b                      |
| Operands:        | $0 \le f \le 127$<br>$0 \le b \le 7$ |
| Operation:       | $1 \rightarrow (f < b >)$            |
| Status Affected: | None                                 |
| Description:     | Bit 'b' in register 'f' is set.      |
|                  |                                      |
|                  |                                      |

| ANDLW            | AND Literal with W                                                                                            |  |  |  |
|------------------|---------------------------------------------------------------------------------------------------------------|--|--|--|
| Syntax:          | [ <i>label</i> ] ANDLW k                                                                                      |  |  |  |
| Operands:        | $0 \leq k \leq 255$                                                                                           |  |  |  |
| Operation:       | (W) .AND. (k) $\rightarrow$ (W)                                                                               |  |  |  |
| Status Affected: | Z                                                                                                             |  |  |  |
| Description:     | The contents of W register are AND'ed with the eight-bit literal 'k'. The result is placed in the W register. |  |  |  |

| BTFSS            | Bit Test f, Skip if Set                                                                                                                                                                     |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [label] BTFSS f,b                                                                                                                                                                           |
| Operands:        | $0 \le f \le 127$<br>$0 \le b < 7$                                                                                                                                                          |
| Operation:       | skip if $(f < b >) = 1$                                                                                                                                                                     |
| Status Affected: | None                                                                                                                                                                                        |
| Description:     | If bit 'b' in register 'f' is '0', the next instruction is executed. If bit 'b' is '1', then the next instruction is discarded and a $\mathtt{NOP}$ is executed instead, making this a 2TCY |

instruction.

| ANDWF            | AND W with f                                                                                                                                       |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [label] ANDWF f,d                                                                                                                                  |
| Operands:        | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                 |
| Operation:       | (W) .AND. (f) $\rightarrow$ (destination)                                                                                                          |
| Status Affected: | Z                                                                                                                                                  |
| Description:     | AND the W register with register 'f'. If 'd' is 0, the result is stored in the W register. If 'd' is 1, the result is stored back in register 'f'. |

| BTFSC            | Bit Test, Skip if Clear                                                                                                                                                                                    |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [label] BTFSC f,b                                                                                                                                                                                          |
| Operands:        | $0 \le f \le 127$<br>$0 \le b \le 7$                                                                                                                                                                       |
| Operation:       | skip if $(f < b >) = 0$                                                                                                                                                                                    |
| Status Affected: | None                                                                                                                                                                                                       |
| Description:     | If bit 'b' in register 'f' is '1', the next instruction is executed.  If bit 'b' in register 'f' is '0', the next instruction is discarded, and a NOP is executed instead, making this a 2Tcy instruction. |

| CLRWDT           | Clear Watchdog Timer                                                                                                  |
|------------------|-----------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ label ] CLRWDT                                                                                                      |
| Operands:        | None                                                                                                                  |
| Operation:       | 00h → WDT<br>0 → WDT prescaler,<br>1 → $\overline{1O}$<br>1 → $\overline{PD}$                                         |
| Status Affected: | TO, PD                                                                                                                |
| Description:     | CLRWDT instruction resets the Watchdog Timer. It also resets the prescaler of the WDT. Status bits TO and PD are set. |

| CALL             | Call Subroutine                                                                                                                                                                                                           |  |  |  |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Syntax:          | [label] CALL k                                                                                                                                                                                                            |  |  |  |
| Operands:        | $0 \le k \le 2047$                                                                                                                                                                                                        |  |  |  |
| Operation:       | $ \begin{array}{l} (PC)+\ 1\rightarrow TOS, \\ k\rightarrow PC<10:0>, \\ (PCLATH<4:3>)\rightarrow PC<12:11> \end{array} $                                                                                                 |  |  |  |
| Status Affected: | None                                                                                                                                                                                                                      |  |  |  |
| Description:     | Call Subroutine. First, return address (PC+1) is pushed onto the stack. The eleven-bit immediate address is loaded into PC bits <10:0>. The upper bits of the PC are loaded from PCLATH. CALL is a two-cycle instruction. |  |  |  |

| COMF             | Complement f                                                                                                                                   |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ label ] COMF f,d                                                                                                                             |
| Operands:        | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                             |
| Operation:       | $(\bar{f}) 	o (destination)$                                                                                                                   |
| Status Affected: | Z                                                                                                                                              |
| Description:     | The contents of register 'f' are complemented. If 'd' is 0, the result is stored in W. If 'd' is 1, the result is stored back in register 'f'. |

| CLRF             | Clear f                                                               |
|------------------|-----------------------------------------------------------------------|
| Syntax:          | [label] CLRF f                                                        |
| Operands:        | $0 \le f \le 127$                                                     |
| Operation:       | $\begin{array}{l} 00h \rightarrow (f) \\ 1 \rightarrow Z \end{array}$ |
| Status Affected: | Z                                                                     |
| Description:     | The contents of register 'f' are cleared and the Z bit is set.        |
|                  |                                                                       |

| DECF             | Decrement f                                                                                                                          |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [label] DECF f,d                                                                                                                     |
| Operands:        | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                   |
| Operation:       | (f) - 1 $\rightarrow$ (destination)                                                                                                  |
| Status Affected: | Z                                                                                                                                    |
| Description:     | Decrement register 'f'. If 'd' is 0, the result is stored in the W register. If 'd' is 1, the result is stored back in register 'f'. |

| CLRW             | Clear W                                                               |
|------------------|-----------------------------------------------------------------------|
| Syntax:          | [label] CLRW                                                          |
| Operands:        | None                                                                  |
| Operation:       | $\begin{array}{l} 00h \rightarrow (W) \\ 1 \rightarrow Z \end{array}$ |
| Status Affected: | Z                                                                     |
| Description:     | W register is cleared. Zero bit (Z) is set.                           |

| DECFSZ                        | Decrement f, Skip if 0                                                                                                                                                                                                                                                                              | INCFSZ           | Increment f, Skip if 0                                                                                                                                                                                                                                                                         |
|-------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:                       | [ label ] DECFSZ f,d                                                                                                                                                                                                                                                                                | Syntax:          | [ label ] INCFSZ f,d                                                                                                                                                                                                                                                                           |
| Operands:                     | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                                                                                                                                                                  | Operands:        | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                                                                                                                                                             |
| Operation:                    | (f) - 1 $\rightarrow$ (destination);<br>skip if result = 0                                                                                                                                                                                                                                          | Operation:       | (f) + 1 $\rightarrow$ (destination),<br>skip if result = 0                                                                                                                                                                                                                                     |
| Status Affected:              | None                                                                                                                                                                                                                                                                                                | Status Affected: | None                                                                                                                                                                                                                                                                                           |
| Description:                  | The contents of register 'f' are decremented. If 'd' is 0, the result is placed in the W register. If 'd' is 1, the result is placed back in register 'f'.  If the result is 1, the next instruction is executed. If the result is 0, then a NOP is executed instead, making it a 2TCY instruction. | Description:     | The contents of register 'f' are incremented. If 'd' is 0, the result is placed in the W register. If 'd' is 1, the result is placed back in register 'f'.  If the result is 1, the next instruction is executed. If the result is 0, a NOP is executed instead, making it a 2TCY instruction. |
| GOTO                          | Unconditional Branch                                                                                                                                                                                                                                                                                | IORLW            | Inclusive OR Literal with W                                                                                                                                                                                                                                                                    |
| Syntax:                       | [ label ] GOTO k                                                                                                                                                                                                                                                                                    | Syntax:          | [ <i>label</i> ] IORLW k                                                                                                                                                                                                                                                                       |
| Operands:                     | $0 \leq k \leq 2047$                                                                                                                                                                                                                                                                                | Operands:        | $0 \leq k \leq 255$                                                                                                                                                                                                                                                                            |
| Operation:                    | $k \rightarrow PC < 10:0 >$                                                                                                                                                                                                                                                                         | Operation:       | (W) .OR. $k \rightarrow$ (W)                                                                                                                                                                                                                                                                   |
|                               | PCLATH<4:3> → PC<12:11>                                                                                                                                                                                                                                                                             | Status Affected: | Z                                                                                                                                                                                                                                                                                              |
| Status Affected: Description: | None GOTO is an unconditional branch. The eleven-bit immediate value is loaded into PC bits <10:0>. The upper bits of PC are loaded from PCLATH<4:3>. GOTO is a two-cycle instruction.                                                                                                              | Description:     | The contents of the W register are OR'ed with the eight-bit literal 'k'. The result is placed in the W register.                                                                                                                                                                               |
| INCF                          | Increment f                                                                                                                                                                                                                                                                                         | IORWF            | Inclusive OR W with f                                                                                                                                                                                                                                                                          |
| Syntax:                       | [ label ] INCF f,d                                                                                                                                                                                                                                                                                  | Syntax:          | [ label ] IORWF f,d                                                                                                                                                                                                                                                                            |
| Operands:                     | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                                                                                                                                                                  | Operands:        | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                                                                                                                                                             |
| Operation:                    | (f) + 1 $\rightarrow$ (destination)                                                                                                                                                                                                                                                                 | Operation:       | (W) .OR. (f) $\rightarrow$ (destination)                                                                                                                                                                                                                                                       |
| Status Affected:              | Z                                                                                                                                                                                                                                                                                                   | Status Affected: | Z                                                                                                                                                                                                                                                                                              |
| Description:                  | The contents of register 'f' are incremented. If 'd' is 0, the result is placed in the W register. If 'd' is 1, the result is placed back in register 'f'.                                                                                                                                          | Description:     | Inclusive OR the W register with register 'f'. If 'd' is 0, the result is placed in the W register. If 'd' is 1, the result is placed back in register 'f'.                                                                                                                                    |

| MOVF             | Move f                                                                                                                                                                                                                                                      |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ label ] MOVF f,d                                                                                                                                                                                                                                          |
| Operands:        | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                                                                                                                          |
| Operation:       | $(f) \to (destination)$                                                                                                                                                                                                                                     |
| Status Affected: | Z                                                                                                                                                                                                                                                           |
| Description:     | The contents of register f are moved to a destination dependant upon the status of d. If $d=0$ , destination is W register. If $d=1$ , the destination is file register f itself. $d=1$ is useful to test a file register, since status flag Z is affected. |

| RETFIE           | Return from Interrupt                         |
|------------------|-----------------------------------------------|
| Syntax:          | [ label ] RETFIE                              |
| Operands:        | None                                          |
| Operation:       | $ TOS \rightarrow PC, $ $ 1 \rightarrow GIE $ |
| Status Affected: | None                                          |
|                  |                                               |
|                  |                                               |
|                  |                                               |
|                  |                                               |

| MOVLW            | Move Literal to W                                                                          |
|------------------|--------------------------------------------------------------------------------------------|
| Syntax:          | [ label ] MOVLW k                                                                          |
| Operands:        | $0 \le k \le 255$                                                                          |
| Operation:       | $k \rightarrow (W)$                                                                        |
| Status Affected: | None                                                                                       |
| Description:     | The eight-bit literal 'k' is loaded into W register. The don't cares will assemble as 0's. |

| RETLW            | Return with Literal in W                                                                                                                                                |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ label ] RETLW k                                                                                                                                                       |
| Operands:        | $0 \le k \le 255$                                                                                                                                                       |
| Operation:       | $\begin{array}{l} k \rightarrow (W); \\ TOS \rightarrow PC \end{array}$                                                                                                 |
| Status Affected: | None                                                                                                                                                                    |
| Description:     | The W register is loaded with the eight-bit literal 'k'. The program counter is loaded from the top of the stack (the return address). This is a two-cycle instruction. |

| MOVWF            | Move W to f                                |
|------------------|--------------------------------------------|
| Syntax:          | [ label ] MOVWF f                          |
| Operands:        | $0 \le f \le 127$                          |
| Operation:       | $(W) \rightarrow (f)$                      |
| Status Affected: | None                                       |
| Description:     | Move data from W register to register 'f'. |

| RETURN           | Return from Subroutine                                                                                                                         |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ label ] RETURN                                                                                                                               |
| Operands:        | None                                                                                                                                           |
| Operation:       | $TOS \to PC$                                                                                                                                   |
| Status Affected: | None                                                                                                                                           |
| Description:     | Return from subroutine. The stack is POPed and the top of the stack (TOS) is loaded into the program counter. This is a two-cycle instruction. |

| NOP              | No Operation  |
|------------------|---------------|
| Syntax:          | [ label ] NOP |
| Operands:        | None          |
| Operation:       | No operation  |
| Status Affected: | None          |
| Description:     | No operation. |

| [ label ] RLF f,d                                                                                                                                                                                 |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                                                                                                                                   |
| 0 ≤ f ≤ 127<br>d ∈ [0,1]                                                                                                                                                                          |
| See description below                                                                                                                                                                             |
| С                                                                                                                                                                                                 |
| The contents of register 'f' are rotated one bit to the left through the Carry Flag. If 'd' is 0, the result is placed in the W register. If 'd' is 1, the result is stored back in register 'f'. |
| 1 1                                                                                                                                                                                               |

| SUBLW            | Subtract W from Literal                                                                                                      |  |
|------------------|------------------------------------------------------------------------------------------------------------------------------|--|
| Syntax:          | [label] SUBLW k                                                                                                              |  |
| Operands:        | $0 \le k \le 255$                                                                                                            |  |
| Operation:       | $k - (W) \rightarrow (W)$                                                                                                    |  |
| Status Affected: | C, DC, Z                                                                                                                     |  |
| Description:     | The W register is subtracted (2's complement method) from the eight-bit literal 'k'. The result is placed in the W register. |  |

| RRF              | Rotate Right f through Carry                                                                                                                                                                       |  |  |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Syntax:          | [ label ] RRF f,d                                                                                                                                                                                  |  |  |
| Operands:        | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                                                                 |  |  |
| Operation:       | See description below                                                                                                                                                                              |  |  |
| Status Affected: | С                                                                                                                                                                                                  |  |  |
| Description:     | The contents of register 'f' are rotated one bit to the right through the Carry Flag. If 'd' is 0, the result is placed in the W register. If 'd' is 1, the result is placed back in register 'f'. |  |  |
|                  | C Register f                                                                                                                                                                                       |  |  |

| SUBWF            | Subtract W from f                                                                                                                                                           |  |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Syntax:          | [ label ] SUBWF f,d                                                                                                                                                         |  |
| Operands:        | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                                          |  |
| Operation:       | (f) - (W) $\rightarrow$ (destination)                                                                                                                                       |  |
| Status Affected: | C, DC, Z                                                                                                                                                                    |  |
| Description:     | Subtract (2's complement method) W register from register 'f'. If 'd' is 0, the result is stored in the W register. If 'd' is 1, the result is stored back in register 'f'. |  |

| Syntax:          | [label] SLEEP                                                                                                                                                                                                        |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operands:        | None                                                                                                                                                                                                                 |
| Operation:       | $\begin{array}{l} \text{00h} \rightarrow \text{WDT,} \\ \text{0} \rightarrow \text{WDT prescaler,} \\ \text{1} \rightarrow \overline{\text{TO}}, \\ \text{0} \rightarrow \overline{\text{PD}} \end{array}$           |
| Status Affected: | TO, PD                                                                                                                                                                                                               |
| Description:     | The power-down status bit, $\overline{PD}$ is cleared. Time-out status bit, $\overline{TO}$ is set. Watchdog Timer and its prescaler are cleared.  The processor is put into SLEEP mode with the oscillator stopped. |

| SWAPF            | Swap Nibbles in f                                                                                                                                              |  |  |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Syntax:          | [ label] SWAPF f,d                                                                                                                                             |  |  |
| Operands:        | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                             |  |  |
| Operation:       | $(f<3:0>) \rightarrow (destination<7:4>),$<br>$(f<7:4>) \rightarrow (destination<3:0>)$                                                                        |  |  |
| Status Affected: | None                                                                                                                                                           |  |  |
| Description:     | The upper and lower nibbles of register 'f' are exchanged. If 'd' is 0, the result is placed in W register. If 'd' is 1, the result is placed in register 'f'. |  |  |

**SLEEP** 

| XORLW                | Exclusive OR Literal with W                                                                                       | XORWF            | Exclusive OR W with f                                                                                                                                                       |
|----------------------|-------------------------------------------------------------------------------------------------------------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:              | [ <i>label</i> ] XORLW k                                                                                          | Syntax:          | [ <i>label</i> ] XORWF f,d                                                                                                                                                  |
| Operands: Operation: | $0 \le k \le 255$ (W) .XOR. $k \to (W)$                                                                           | Operands:        | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                                          |
| Status Affected:     | Z                                                                                                                 | Operation:       | (W) .XOR. (f) $\rightarrow$ (destination)                                                                                                                                   |
| ar<br>er             | The contents of the W register are XOR'ed with the eight-bit literal 'k'. The result is placed in the W register. | Status Affected: | Z                                                                                                                                                                           |
|                      |                                                                                                                   | Description:     | Exclusive OR the contents of the W register with register 'f'. If 'd' is 0, the result is stored in the W register. If 'd' is 1, the result is stored back in register 'f'. |